<template>
  <div class="JNPF-common-layout">
    <div class="JNPF-common-layout-center">
      <el-row class="JNPF-common-search-box" :gutter="16">
        <el-form @submit.native.prevent>
          <el-col :span="6">
            <el-form-item label="企业名称">
              <el-input v-model="query.enterpriseName" placeholder="请输入" clearable></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="企业信用代码">
              <el-input v-model="query.enterpriseCreditCode" placeholder="请输入" clearable></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="区县">
              <JnpfSelect v-model="query.county" placeholder="请选择" clearable :options="countyOptions"
                :props="countyProps" multiple>
              </JnpfSelect>
            </el-form-item>
          </el-col>
          <template v-if="showAll">
            <el-col :span="6">
              <el-form-item label="状态">
                <JnpfSelect v-model="query.status" placeholder="请选择" clearable :options="statusOptions"
                  :props="statusProps" multiple>
                </JnpfSelect>
              </el-form-item>
            </el-col>
          </template>
          <el-col :span="6">
            <el-form-item>
              <el-button type="primary" icon="el-icon-search" @click="search()">查询</el-button>
              <el-button icon="el-icon-refresh-right" @click="reset()">重置</el-button>
              <el-button type="text" icon="el-icon-arrow-down" @click="showAll = true" v-if="!showAll">
                展开
              </el-button>
              <el-button type="text" icon="el-icon-arrow-up" @click="showAll = false" v-else>
                收起
              </el-button>
            </el-form-item>
          </el-col>
        </el-form>
      </el-row>
      <div class="JNPF-common-layout-main JNPF-flex-main">
        <div class="JNPF-common-head">
          <div>
          </div>
          <div class="JNPF-common-head-right">
            <el-tooltip content="高级查询" placement="top" v-if="true">
              <el-link icon="icon-ym icon-ym-filter JNPF-common-head-icon" :underline="false"
                @click="openSuperQuery()" />
            </el-tooltip>
            <el-tooltip effect="dark" :content="$t('common.refresh')" placement="top">
              <el-link icon="icon-ym icon-ym-Refresh JNPF-common-head-icon" :underline="false" @click="initData()" />
            </el-tooltip>
          </div>
        </div>
        <JNPF-table v-loading="listLoading" :data="list" @sort-change='sortChange' :span-method="arraySpanMethod">
          <el-table-column label="区县" prop="county" algin="left" width="60">
            <template slot-scope="scope">
              {{ scope.row.county }}
            </template>
          </el-table-column>
          <el-table-column prop="enterpriseName" label="企业名称" align="left" width="180"></el-table-column>
          <el-table-column prop="enterpriseCreditCode" label="企业信用代码" align="left" width="180"></el-table-column>
          <el-table-column prop="projectNames" label="项目名称" align="left" min-width="250"></el-table-column>
          <el-table-column prop="phone" label="联系电话" align="left" width="100"></el-table-column>
          <el-table-column prop="flowState" label="状态" width="100">
            <template slot-scope="scope" v-if="!scope.row.top">
              <el-tag v-if="scope.row.flowState == 1">审核中</el-tag>
              <el-tag type="success" v-else-if="scope.row.flowState == 2">已审核</el-tag>
              <el-tag v-else-if="scope.row.flowState == 3">审核中</el-tag>
              <el-tag v-else-if="scope.row.flowState == 4">审核中</el-tag>
              <el-tag type="info" v-else-if="scope.row.flowState == 5">审核终止</el-tag>
              <el-tag type="warning" v-else>等待提交</el-tag>
            </template>
          </el-table-column>
          <el-table-column label="操作" fixed="right" width="130">
            <template slot-scope="scope">
              <el-button size="mini" type="text" :disabled="!scope.row.flowState"
                @click="updateHandle(scope.row, scope.row.flowState)">查看
              </el-button>
              <el-button type="text"
                v-if="(scope.row.flowState === 2 ? true : false) && (scope.row.isconfirm !== '确认' ? true : false)"
                @click="goConfirm(scope.row.id, scope.row.isconfirm, scope.row.enterpriseCreditCode)">
                同意验收
              </el-button>
              <el-button type="text" class="confirm-text" v-if="scope.row.isconfirm === '确认' ? true : false">
                已同意
              </el-button>
            </template>
          </el-table-column>
        </JNPF-table>
        <pagination :total="total" :page.sync="listQuery.currentPage" :limit.sync="listQuery.pageSize"
          @pagination="initData" />
      </div>
    </div>
    <JNPF-Form v-if="formVisible" ref="JNPFForm" @refresh="refresh" />
    <ExportBox v-if="exportBoxVisible" ref="ExportBox" @download="download" />


    <FlowBox v-if="flowVisible" ref="FlowBox" @close="colseFlow" />
    <el-dialog title="请选择流程" :close-on-click-modal="false" append-to-body :visible.sync="flowListVisible"
      class="JNPF-dialog template-dialog JNPF-dialog_center" lock-scroll width="400px">
      <el-scrollbar class="template-list">
        <div class="template-item" v-for="item in flowList" :key="item.id" @click="selectFlow(item)">{{ item.fullName }}
        </div>
      </el-scrollbar>
    </el-dialog>

    <ImportBox v-if="uploadBoxVisible" ref="UploadBox" @refresh="initData" />
    <Detail v-if="detailVisible" ref="Detail" @refresh="detailVisible = false" />
    <ToFormDetail v-if="toFormDetailVisible" ref="toFormDetail" @close="toFormDetailVisible = false" />
    <SuperQuery v-if="superQueryVisible" ref="SuperQuery" :columnOptions="superQueryJson" @superQuery="superQuery" />
  </div>
</template>

<script>

import request from '@/utils/request'
import axios from "axios";
import { mapGetters } from "vuex";
import { getDictionaryDataSelector } from '@/api/systemData/dictionary'
import { getFormById } from '@/api/workFlow/FormDesign'
import { getFlowList } from '@/api/workFlow/FlowEngine'
import FlowBox from '@/views/workFlow/components/FlowBox'
import ExportBox from '@/components/ExportBox'
import ToFormDetail from '@/views/basic/dynamicModel/list/detail'
import { getDataInterfaceRes } from '@/api/systemData/dataInterface'
import { getConfigData } from '@/api/onlineDev/visualDev'
import { getDefaultCurrentValueUserIdAsync } from '@/api/permission/user'
import { getDefaultCurrentValueDepartmentIdAsync } from '@/api/permission/organize'
import columnList from './columnList'
import { thousandsFormat } from "@/components/Generator/utils/index"
import SuperQuery from '@/components/SuperQuery'
import superQueryJson from './superQueryJson'

export default {
  components: {
    FlowBox,
    ExportBox, ToFormDetail, SuperQuery
  },
  data() {
    return {
      keyword: '',
      expandsTree: true,
      refreshTree: true,
      toFormDetailVisible: false,
      expandObj: {},
      columnOptions: [],
      mergeList: [],
      exportList: [],
      columnList,
      showAll: false,
      superQueryVisible: false,
      superQueryJson,
      uploadBoxVisible: false,
      detailVisible: false,
      query: {
        enterpriseName: undefined,
        enterpriseCreditCode: undefined,
        projectId: undefined,
        county: undefined,
        digitizationLevel: undefined,
        status: undefined,
      },
      treeProps: {
        children: 'children',
        label: 'fullName',
        value: 'id',
        isLeaf: 'isLeaf'
      },
      list: [],
      listLoading: true,
      total: 0,
      queryData: {},
      listQuery: {
        superQueryJson: '',
        currentPage: 1,
        pageSize: 20,
        sort: "desc",
        sidx: "status",
      },
      formVisible: false,
      flowVisible: false,
      flowListVisible: false,
      flowList: [],
      exportBoxVisible: false,
      countyOptions: [{ "fullName": "鼓楼区", "id": "鼓楼区" }, { "fullName": "台江区", "id": "台江区" }, {
        "fullName": "仓山区",
        "id": "仓山区"
      }, { "fullName": "马尾区", "id": "马尾区" }, { "fullName": "晋安区", "id": "晋安区" }, {
        "fullName": "长乐区",
        "id": "长乐区"
      }, { "fullName": "闽侯县", "id": "闽侯县" }, { "fullName": "连江县", "id": "连江县" }, {
        "fullName": "罗源县",
        "id": "罗源县"
      }, { "fullName": "闽清县", "id": "闽清县" }, { "fullName": "永泰县", "id": "永泰县" }, {
        "fullName": "福清市",
        "id": "福清市"
      }, { "fullName": "高新区", "id": "高新区" }],
      countyProps: { "label": "fullName", "value": "id" },
      acceptIspassOptions: [{ "fullName": "建议通过", "id": "1" }, { "fullName": "建议整改", "id": "0" }],
      acceptIspassProps: { "label": "fullName", "value": "id" },
      isconfirmOptions: [{ "fullName": "确认", "id": "1" }, { "fullName": "未确认", "id": "0" }],
      isconfirmProps: { "label": "fullName", "value": "id" },
      digitizationLevelOptions: [{ "fullName": "无等级", "id": "0" }, { "fullName": "一级", "id": "1" }, {
        "fullName": "二级",
        "id": "2"
      }, { "fullName": "三级", "id": "3" }, { "fullName": "四级", "id": "4" }],
      digitizationLevelProps: { "label": "fullName", "value": "id" },
      statusOptions: [{ "fullName": "已审核", "id": "2" }, { "fullName": "审核中", "id": "1" }, { "fullName": "等待提交", "id": "0" }],
      statusProps: { "label": "fullName", "value": "id" },
      interfaceRes: {},
    }
  },
  computed: {
    ...mapGetters(['userInfo']),
    menuId() {
      return this.$route.meta.modelId || ''
    }
  },
  created() {
    getFormById("566267928102570309").then(res1 => {
      let flowId = res1.data && res1.data.id
      getFlowList(flowId, '1').then(res2 => {
        this.flowList = res2.data
        this.getColumnList(),
          this.initSearchDataAndListData()
        this.queryData = JSON.parse(JSON.stringify(this.query))
      }).catch((e) => {
        this.$message({ type: 'error', message: e.message });
        this.$router.push('/404');
      })
    })
  },
  methods: {
    getClassName(isconfirm) {
      return isconfirm === '确认' || isconfirm === '通过' ? 'confirm-text' : 'unconfirm-text';
    },
    goConfirm(id, isconfirm, enterpriseCreditCode) {
      if (isconfirm === '确认') {
        this.$message({
          type: 'info',
          message: '该企业已同意开始验收'
        });
      } else {
        this.$confirm('此操作将同意该企业的验收申请, 是否继续?', '提示', {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning'
        }).then(() => {
          let url = `/api/system/DataInterface/573522460893249989/Actions/Preview`;
          let params = {
            "paramList": [
              {
                "id": "7bvOr92",
                "field": "id",
                "defaultValue": id,
                "fieldName": "",
                "dataType": "varchar",
                "required": 1
              }
            ],
            "tenantId": "",
            "origin": "preview"
          };
          request({
            url: url,
            method: 'post',
            data: params
          }).then(res => {
            //给企业发送通知
           /* const url = `http://test-fzzxqy.demo-caii.com/cloud-api2//fzzxqyz/afterAcceptanceSendMessage?code=${enterpriseCreditCode}`;
            axios.get(url).then(res => {
              if (res.data.message == "success") {
                this.initData()
                this.$message({
                  type: 'success',
                  message: '操作成功, 验收开始通知已发送给该企业。'
                });
              } else {
                this.$message.error('发送验收开始通知失败，请联系管理员解决！');
              }
            })*/
            this.$message({
              type: 'success',
              message: '已同意验收!',
              onClose: () => {
                this.initData()
              }
            });
          })
        }).catch(() => {
          this.$message({
            type: 'info',
            message: '取消操作'
          });
        });
      }
    },
    toDetail(defaultValue, modelId) {
      if (!defaultValue) return
      getConfigData(modelId).then(res => {
        if (!res.data || !res.data.formData) return
        let formData = JSON.parse(res.data.formData)
        formData.popupType = 'general'
        this.toFormDetailVisible = true
        this.$nextTick(() => {
          this.$refs.toFormDetail.init(formData, modelId, defaultValue)
        })
      })
    },
    toggleTreeExpand(expands) {
      this.refreshTree = false
      this.expandsTree = expands
      this.$nextTick(() => {
        this.refreshTree = true
        this.$nextTick(() => {
          this.$refs.treeBox.setCurrentKey(null)
        })
      })
    },
    filterNode(value, data) {
      if (!value) return true;
      return data[this.treeProps.label].indexOf(value) !== -1;
    },
    loadNode(node, resolve) {
      const nodeData = node.data
      const config = {
        treeInterfaceId: "",
        treeTemplateJson: []
      }
      if (config.treeInterfaceId) {
        //这里是为了拿到参数中关联的字段的值，后端自行拿
        if (config.treeTemplateJson && config.treeTemplateJson.length) {
          for (let i = 0; i < config.treeTemplateJson.length; i++) {
            const element = config.treeTemplateJson[i];
            element.defaultValue = nodeData[element.relationField] || ''
          }
        }
        //参数
        let query = {
          paramList: config.treeTemplateJson || [],
        }
        //接口
        getDataInterfaceRes(config.treeInterfaceId, query).then(res => {
          let data = res.data
          if (Array.isArray(data)) {
            resolve(data);
          } else {
            resolve([]);
          }
        })
      }
    },
    getColumnList() {
      // 没有开启权限
      this.columnOptions = this.transformColumnList(this.columnList)
    },
    transformColumnList(columnList) {
      let list = []
      for (let i = 0; i < columnList.length; i++) {
        const e = columnList[i];
        if (!e.prop.includes('-')) {
          list.push(e)
        } else {
          let prop = e.prop.split('-')[0]
          let label = e.label.split('-')[0]
          let vModel = e.prop.split('-')[1]
          let newItem = {
            align: "center",
            jnpfKey: "table",
            prop,
            label,
            children: []
          }
          e.vModel = vModel
          if (!this.expandObj.hasOwnProperty(`${prop}Expand`)) this.$set(this.expandObj, `${prop}Expand`, false)
          if (!list.some(o => o.prop === prop)) list.push(newItem)
          for (let i = 0; i < list.length; i++) {
            if (list[i].prop === prop) {
              list[i].children.push(e)
              break
            }
          }
        }
      }
      this.getMergeList(list)
      this.getExportList(list)
      return list
    },
    arraySpanMethod({ column }) {
      for (let i = 0; i < this.mergeList.length; i++) {
        if (column.property == this.mergeList[i].prop) {
          return [this.mergeList[i].rowspan, this.mergeList[i].colspan]
        }
      }
    },
    getMergeList(list) {
      let newList = JSON.parse(JSON.stringify(list))
      newList.forEach(item => {
        if (item.children && item.children.length) {
          let child = {
            prop: item.prop + '-child-first'
          }
          item.children.unshift(child)
        }
      })
      newList.forEach(item => {
        if (item.children && item.children.length) {
          item.children.forEach((child, index) => {
            if (index == 0) {
              this.mergeList.push({
                prop: child.prop,
                rowspan: 1,
                colspan: item.children.length
              })
            } else {
              this.mergeList.push({
                prop: child.prop,
                rowspan: 0,
                colspan: 0
              })
            }
          })
        } else {
          this.mergeList.push({
            prop: item.prop,
            rowspan: 1,
            colspan: 1
          })
        }
      })
    },
    getExportList(list) {
      let exportList = []
      for (let i = 0; i < list.length; i++) {
        if (list[i].jnpfKey === 'table') {
          for (let j = 0; j < list[i].children.length; j++) {
            exportList.push(list[i].children[j])
          }
        } else {
          exportList.push(list[i])
        }
      }
      this.exportList = exportList
    },
    goDetail(id) {
      this.detailVisible = true
      this.$nextTick(() => {
        this.$refs.Detail.init(id)
      })
    },
    sortChange({ column, prop, order }) {
      this.listQuery.sort = order == 'ascending' ? 'asc' : 'desc'
      this.listQuery.sidx = !order ? '' : prop
      this.initData()
    },
    async initSearchDataAndListData() {
      await this.initSearchData()
      this.initData()
    },
    //初始化查询的默认数据
    async initSearchData() {
    },
    initData() {
      this.listLoading = true;
      let _query = {
        ...this.listQuery,
        ...this.query,
        keyword: this.keyword,
        dataType: 0,
        menuId: this.menuId,
        moduleId: '566267928102570309',
        type: 1,
      };
      request({
        url: `/api/example/Fz_company_acceptance_apply/getList`,
        method: 'post',
        data: _query
      }).then(res => {
        var _list = res.data.list;
        this.list = _list.map(o => ({
          ...o,
          ...this.expandObj,
        }))
        this.total = res.data.pagination.total
        this.listLoading = false
      })
    },
    handleDel(id) {
      this.$confirm('此操作将永久删除该数据, 是否继续?', '提示', {
        type: 'warning'
      }).then(() => {
        request({
          url: `/api/example/Fz_company_acceptance_apply/${id}`,
          method: 'DELETE'
        }).then(res => {
          this.$message({
            type: 'success',
            message: res.msg,
            onClose: () => {
              this.initData()
            }
          });
        })
      }).catch(() => {
      });
    },
    handelUpload() {
      this.uploadBoxVisible = true
      this.$nextTick(() => {
        this.$refs.UploadBox.init("", "example/Fz_company_acceptance_apply")
      })
    },
    openSuperQuery() {
      this.superQueryVisible = true
      this.$nextTick(() => {
        this.$refs.SuperQuery.init()
      })
    },
    superQuery(queryJson) {
      this.listQuery.superQueryJson = queryJson
      this.listQuery.currentPage = 1
      this.initData()
    },
    addOrUpdateHandle(row, flowState) {
      if (!row) {
        this.addHandle();
      } else {
        this.updateHandle(row, flowState)
      }
    },
    exportData() {
      this.exportBoxVisible = true
      this.$nextTick(() => {
        this.$refs.ExportBox.init(this.exportList)
      })
    },
    download(data) {
      let query = { ...data, ...this.listQuery, ...this.query, menuId: this.menuId }
      request({
        url: `/api/example/Fz_company_acceptance_apply/Actions/Export`,
        method: 'post',
        data: query
      }).then(res => {
        if (!res.data.url) return
        this.jnpf.downloadFile(res.data.url)
        this.$refs.ExportBox.visible = false
        this.exportBoxVisible = false
      })
    },
    search() {
      this.listQuery.currentPage = 1
      this.listQuery.pageSize = 20
      this.listQuery.sort = "desc"
      this.listQuery.sidx = "status"
      this.initData()
    },
    //流程改造后相关调用方法
    updateHandle(row, flowState) {
      let data = {
        id: row.id,
        flowId: row.flowId || this.flowList[0].id,
        opType: flowState ? 0 : '-1',
        status: flowState
      }
      this.flowVisible = true
      this.$nextTick(() => {
        this.$refs.FlowBox.init(data)
      })
    },
    toApprovalDetail(row) {
      let data = {
        id: row.id,
        flowId: row.flowId,
        opType: 0,
        status: row.currentState
      }
      this.formVisible = true
      this.$nextTick(() => {
        this.$refs.FlowBox.init(data)
      })
    },
    addHandle() {
      if (!this.flowList.length) {
        this.$message({ type: 'error', message: '流程不存在' });
      } else if (this.flowList.length === 1) {
        this.selectFlow(this.flowList[0])
      } else {
        this.flowListVisible = true
      }
    },
    //选择流程发起
    selectFlow(item) {
      let data = {
        id: '',
        formType: 1,
        flowId: item.id,
        opType: '-1'
      }
      this.flowListVisible = false
      this.flowVisible = true
      this.$nextTick(() => {
        this.$refs.FlowBox.init(data)
      })
    },
    refresh(isrRefresh) {
      this.formVisible = false
      if (isrRefresh) this.reset()
    },
    reset() {
      this.query = JSON.parse(JSON.stringify(this.queryData))
      this.search()
    },
    colseFlow(isrRefresh) {
      this.flowVisible = false
      if (isrRefresh) this.reset()
    },
  }
}
</script>
<style lang="scss" scoped>
.confirm-text {
  color: #67C23A;
}

.unconfirm-text {
  color: #f56c6c;
}
</style>
